草庐IT

ios - 根据找到的字符换行

全部标签

ruby - 如何验证字符串是 Ruby 中的正确十六进制值?

我正在用Ruby编写一个6502汇编器。我正在寻找一种方法来验证字符串形式的十六进制操作数。我知道String对象提供了一个“十六进制”方法来返回一个数字,但是我遇到了一个问题:"0A".hex#=>10-avalidhexadecimalvalue"0Z".hex#=>0-invalid,producesazero"asfd".hex#=>10-Why10?Iguessitreads'a'firstandstopsat's'?输入一堆乱码会得到一些奇怪的结果。我需要的是一种方法来首先验证该值是合法的十六进制字符串。我在玩正则表达式,并意识到我可以做到这一点:trueif"0A"=~/

ruby gsub 换行符

我有一个包含换行符的字符串,我想用gsub替换空白。"helloI\r\namatest\r\n\r\nstring".gsub(/[\\r\\n]/,'')类似这样的事情^只有我的正则表达式似乎也在替换'r'和'n'字母。另一个约束是有时模式会重复两次,因此会被一行中的两个空格替换,尽管这不是可取的,但比所有文本都被切开要好。如果有办法只选择换行符。或者,如果在使用正则表达式之外还有更简单的方法来解决这个问题,那就更好了? 最佳答案 如果您有混合的连续换行符并想用单个空格替换,您可以使用以下正则表达式解决方案:s.gsub(/\R

ruby - 格式化日期时间字符串

我需要我的字符串"Wed,26May201714:00:00+0800"格式为2017-05-2614:00:00+0800(可以将其保留为字符串但不是强制性的)。什么是最快的方法? 最佳答案 parse字符串并通过strftime重新格式化它:string='Wed,26May201714:00:00+0800'Time.parse(string).strftime('%F%T%z')#=>"2017-05-2614:00:00+0800" 关于ruby-格式化日期时间字符串,我们在S

ruby-on-rails - 西里尔字符串 Я̆ Я̄ Я̈ 在 ruby​​ 和其他编程语言中返回长度 2 而不是 1

在Ruby、Javascript和Java(其他我没试过)中,有西里尔字符Я̆Я̄Я̈长度2。当我尝试用这些字符检查字符串的长度时,我得到了错误的输出值。"Я̈".mb_chars.length#=>2#shouldbe1(rubyonrails)"Я̆".length#=>2#shouldbe1(ruby,javascript)"Ӭ".length#=>1#correct(ruby,javascript)请注意,字符串以UTF-8编码,每个字符都表现为单个字符。我的问题是为什么会有这样的行为,我怎样才能正确地得到带有这些字符的字符串的长度? 最佳答案

ruby - 检查字符串变量是否在一组字符串中

哪个更好:x=='abc'||x=='def'||x=='ghi'%w(abcdefghi).include?xx=~/abc|def|ghi/? 最佳答案 哪个更好?这个问题不容易回答,因为他们做的事情不尽相同。x=='abc'||x=='def'||x=='ghi'%w(abcdefghi).include?x比较x与固定字符串是否相等。x必须是这些值之一。在这两者之间,我倾向于选择第二个,因为它更容易维护。想象一下,如果您必须与20、50或100个字符串进行比较会是什么样子。第三个测试:x~=/abc|def|ghi/匹配子串

ruby - 使用 Mechanize gem 根据链接在 DOM 中的位置返回链接集合

我正在为Mechanize而苦苦挣扎。我希望“单击”一组只能通过其位置(div#content中的所有链接)或其href来识别的链接。以上两种识别方法我都试过了,都没有成功。从文档中,我无法弄清楚如何根据链接在DOM中的位置而不是直接通过链接上的属性返回一组链接(用于单击)。其次,documentation建议你可以使用:href来匹配部分href,page=agent.get('http://foo.com/').links_with(:href=>"/something")但我让它返回链接的唯一方法是传递一个完全限定的URL,例如page=agent.get('http://foo

ruby-on-rails - ruby 1.8 和 1.9 之间的字符串长度差异

我有一个运行在ruby​​1.8.7上的网站。我对传入的帖子进行了验证,检查以确保我们最多允许12000个字符。在对帖子进行验证之前,空格被计为字符,制表符和回车符被去除。这是经过验证的帖子http://pastie.org/5047582在ruby​​1.9中,字符串长度显示为11909,这是正确的。但是当我检查ruby​​1.8.7的长度时,结果是12044。我使用codepad.org运行这个ruby​​代码,它给了我http://codepad.org/OxgSuKGZ(输出长度为12044,这是错误的)但是当我在codeacademy.org的控制台中运行相同的代码时,字符串

ruby-on-rails - 带分号的字符串在 RubyMine 中产生 "unterminated string meets end of file"

在RubyMine调试器中,只需在watch中输入:';'或";"我收到错误:"unterminatedstringmeetsendoffile"这是为什么?据我所知,它不会发生在Rails控制台中,并且与RubyMine没有任何关系。 最佳答案 这是Ruby调试器与Ruby解释器具有不同解析规则的结果。事实上,从irb或ruby命令调用的常规Ruby调试器表现出相同的行为。然而,解决方法很简单:要创建一个由单个分号组成的字符串文字,只需使用反斜杠将其转义即可:$irb>require'debugger'=>true>debugge

ruby - 为什么这两个不同的正则表达式根据下划线的位置在 Ruby 中返回不同的结果

我有以下内容:.[11]pry(main)>"abBN123-4.56".scan(/BN([0-9_\.-]+)/)=>[["123-4.56"]][12]pry(main)>"abBN123-4.56".scan(/BN([0-9\.-_]+)/)=>[["123"]]我不确定为什么第二个末尾带有下划线的行为与第一个行为不同。RegEx解析器如何解释它以使其不同? 最佳答案 这是因为您将连字符(-)放在了字符类的中间而没有被转义。在字符类[]中,您可以放置​​一个连字符(-)作为first或last性格。如果您将连字符放在其他任

ruby-on-rails - 在 El Capitan 上安装 Rails 时出现 -lgmp 错误的库未找到(Mac OS 10.11.1 (15B42))

在使用Rubyv2.2.2的ElCapitan(MacOSX10.11.1)上安装Rails时,出现以下错误:ERROR:Errorinstallingnokogiri:ERROR:Failedtobuildgemnativeextension./Users/jon/.rvm/rubies/ruby-2.2.2/bin/ruby-r./siteconf20151117-26799-ux15fd.rbextconf.rb--use-system-librariescheckingiftheCcompileraccepts...***extconf.rbfailed***Couldnotc